{{tag>Trusty Xenial fenêtre_de_connexion GNOME tutoriel}}

----

====== Personnaliser l'arrière-plan de GDM ======

**[[:GDM]]** est le [[:fenêtre de connexion|gestionnaire de sessions]] de l'[[:environnements|environnement]] [[:GNOME]] et son bureau [[:GNOME Shell]].

Son arrière-plan par défaut est (selon les versions) soit gris avec une légère texture, soit violet uniforme. Ce n'est pas forcément très chaleureux, on va donc voir comment modifier cet arrière-plan.

<note warning>GDM n'a pas été conçu d'une manière facilement configurable. Les manipulations qui vont suivre sont par conséquent risquées pour votre système. Faites attention à :
  * Avoir sauvegardé une version originale des données que vous modifiez ;
  * Avoir la version concernée par la partie que vous appliquez ;
  * Ne pas faire la moindre faute de frappe.

Les mises à niveau, voire les mises à jour, risquent par ailleurs de réinitialiser vos configurations.</note>

Depuis la version GNOME 3.16, les thèmes de GNOME Shell (et donc de GDM) sont stockés dans des fichiers binaires (au format gresource). Il va donc falloir extraire le thème de ce fichier, le modifier, puis le recompiler.

===== Pré-requis =====

Les **droits d'administrations** seront nécessaires afin d'utiliser la commande [[:sudo]].

L'image à mettre en arrière-plan doit être au format ''.png'' (et si possible ne pas contenir de transparence).

===== Extraire le thème utilisé =====

Pour extraire le thème par défaut, vous pouvez utiliser le script ''extractgst.sh'' suivant :

<file bash>#!/bin/sh

workdir=${HOME}
if [ ! -d ${workdir}/shell-theme ]; then
  mkdir -p ${workdir}/shell-theme
fi
gst=/usr/share/gnome-shell/gnome-shell-theme.gresource

for r in `gresource list $gst`; do
        gresource extract $gst $r >$workdir/${r#\/org\/gnome\/shell/}
done</file>

Exécutez ce script.

===== Modifier le thème =====

Après avoir exécuté le script, ouvrez le répertoire ''shell-theme'' créé dans votre dossier personnel. Vous devriez y trouver les fichiers du thème qui y ont été extraits.

==== L'image ====

Renommer votre image de fond d'écran en ''noise-texture.png'', puis copiez-la dans le dossier ''shell-theme'' (écrasez l'ancienne version).

==== Le fichier XML ====

Ensuite vous devez créer, toujours dans ce répertoire, le fichier ''gnome-shell-theme.gresource.xml'' avec le contenu suivant:

<code><?xml version="1.0" encoding="UTF-8"?>
<gresources>
  <gresource prefix="/org/gnome/shell/theme">
    <file>calendar-arrow-left.svg</file>
    <file>calendar-arrow-right.svg</file>
    <file>calendar-today.svg</file>
    <file>checkbox-focused.svg</file>
    <file>checkbox-off-focused.svg</file>
    <file>checkbox-off.svg</file>
    <file>checkbox.svg</file>
    <file>close-window.svg</file>
    <file>close.svg</file>
    <file>corner-ripple-ltr.png</file>
    <file>corner-ripple-rtl.png</file>
    <file>dash-placeholder.svg</file>
    <file>filter-selected-ltr.svg</file>
    <file>filter-selected-rtl.svg</file>
    <file>gnome-shell.css</file>
    <file>gnome-shell-high-contrast.css</file>
    <file>logged-in-indicator.svg</file>
    <file>no-events.svg</file>
    <file>no-notifications.svg</file>
    <file>noise-texture.png</file>
    <file>page-indicator-active.svg</file>
    <file>page-indicator-inactive.svg</file>
    <file>page-indicator-checked.svg</file>
    <file>page-indicator-hover.svg</file>
    <file>process-working.svg</file>
    <file>running-indicator.svg</file>
    <file>source-button-border.svg</file>
    <file>summary-counter.svg</file>
    <file>toggle-off-us.svg</file>
    <file>toggle-off-intl.svg</file>
    <file>toggle-on-hc.svg</file>
    <file>toggle-on-us.svg</file>
    <file>toggle-on-intl.svg</file>
    <file>ws-switch-arrow-up.png</file>
    <file>ws-switch-arrow-down.png</file>
  </gresource>
</gresources></code>

Ensuite, ouvrez le fichier ''gnome-shell.css'' pour vérifier que la section ''#lockDialogGroup'' correspond bien à :

==== Le fichier CSS ====

<file css>#lockDialogGroup {
  background: #2e3436 url(noise-texture.png);
  background-repeat: no-repeat;
}</file>

<note help>Le "#2e3436" correspond à la couleur, en hexadécimal, qui s'affiche si l'image est mal cadrée ou transparente, sa valeur n'est pas très importante ici.
</note>

Vous devrez sans doute spécifier la résolution de GDM - ce n'est pas forcément celle de l'image - avec le paramètre ci-dessous à ajouter à la section ''#lockDialogGroup'' (bien sûr, [WIDTH] et [HEIGHT] sont à remplacer par vos valeurs) :
<file css>background-size: [WIDTH]px [HEIGHT]px;</file>

==== Compiler ====

Enfin, ouvrez un terminal pour recompiler votre thème avec les commandes suivantes :
<code>cd ~/shell-theme
glib-compile-resources gnome-shell-theme.gresource.xml</code>

<note help>
Si la compilation renvoie une erreur à propos de ''more-results.svg'', ajoutez la ligne suivante au milieu du fichier XML précédemment créé :
<code>    <file>more-results.svg</file></code>
Puis recompilez.
</note>

===== Mettre le thème en place =====

Il ne vous reste plus qu'à copier dans ''/usr/share/gnome-shell'' le ficher ''gnome-shell-theme.gresource'' qui vient de se créer.
<note important>Il est pertinent de faire une copie de sauvegarde de son thème par défaut avant d'écraser le fichier d'origine :
<code>cp /usr/share/gnome-shell/gnome-shell-theme.gresource ~/shell-theme/gnome-shell-theme.gresource.old</code>
</note>
<code>sudo mv ~/shell-theme/gnome-shell-theme.gresource /usr/share/gnome-shell</code>

Les modifications prendront effet au redémarrage.

===== À partir d'Ubuntu 17.10 =====

Le thème par défaut de GDM est modifié pour assurer une cohérence visuelle avec la session "Ubuntu" par défaut((https://didrocks.fr/2017/09/11/ubuntu-gnome-shell-in-artful-day-11/)).

Le paragraphe précédent diffère donc légèrement sur plusieurs aspects : le fichier ''gnome-shell.css'' n'est pas utilisé par le système, il s'agira plutôt de ''ubuntu.css'' qui donnera au fond de l'écran cette couleur violette caractéristique.

<note>Si vous installez le paquet [[apt>gnome-session]], il est possible de récupérer le thème par défaut en lançant la commande suivante **en tant qu'administrateur** :
<code>update-alternatives --config gdm3.css</code>
Choisissez alors ''gnome-shell.css'' en tapant le numéro adéquat.
</note>

===== Voir aussi =====

  * **(fr)** [[https://wiki.debian.org/fr/GDM|Documentation sur GDM pour la personnalisation]],
  * **(en)** [[https://wiki.gnome.org/Projects/GDM|Site officiel]]
  * [[:GDM]]
  * **(en)** [[https://didrocks.fr/2017/09/11/ubuntu-gnome-shell-in-artful-day-11/|À propos du thème par défaut à partir de 17.10]]

----

//Contributeurs principaux : [[:utilisateurs:J5012]], [[:utilisateurs:claudiux]], [[:utilisateurs:deobs]], [[:utilisateurs/roschan]]
, ...//
